<template>
  <div class="register-container">
    <!-- 注册内容 -->
    <div class="register">
      <h3>
        注册新用户
        <span class="go"
          >我有账号，去 <router-link :to="{ path: '/login' }">登陆</router-link>
        </span>
      </h3>
      <div class="content">
        <label>手机号:</label>
        <input
          type="text"
          placeholder="请输入你的手机号"
          v-model="data.phoneNum"
        />
        <span class="error-msg" v-show="!data.phoneNum">手机号不能为空</span>
      </div>
      <div class="content">
        <label>验证码:</label>
        <input
          type="text"
          placeholder="请输入验证码"
          v-model="data.userCode"
          @input="inputCode"
        />
        <img
          ref="code"
          src="http://182.92.128.115/api/user/passport/code"
          alt="code"
          @click="getUserCode"
        />
        <span class="error-msg" v-show="!data.codeIsTrue">验证码错误</span>
      </div>
      <div class="content">
        <label>登录密码:</label>
        <input
          type="text"
          placeholder="请输入你的登录密码"
          v-model="data.password"
        />
        <span class="error-msg" v-show="data.password ? false : true"
          >密码不能为空</span
        >
      </div>
      <div class="content">
        <label>确认密码:</label>
        <input
          type="text"
          placeholder="请输入确认密码"
          @input="againPassword"
        />
        <span class="error-msg" v-show="!data.isEqual">两次密码不一致</span>
      </div>
      <div class="controls">
        <input name="m1" type="checkbox" v-model="data.isAgree" />
        <span>同意协议并注册《尚品汇用户协议》</span>
        <span class="error-msg" v-show="!data.isAgree">请同意协议</span>
      </div>
      <div class="btn">
        <button
          :disabled="
            data.isAgree && data.isAgree && data.isEqual ? false : true
          "
          @click="goRegister"
        >
          完成注册
        </button>
      </div>
    </div>

    <!-- 底部 -->
    <div class="copyright">
      <ul>
        <li>关于我们</li>
        <li>联系我们</li>
        <li>联系客服</li>
        <li>商家入驻</li>
        <li>营销中心</li>
        <li>手机尚品汇</li>
        <li>销售联盟</li>
        <li>尚品汇社区</li>
      </ul>
      <div class="address">地址：北京市昌平区宏福科技园综合楼6层</div>
      <div class="beian">京ICP备19006430号</div>
    </div>
  </div>
</template>

<script lang="ts" setup>
import { reactive, ref } from "vue";
import { getCode, register } from "@/api/getUser";

const data = reactive({
  //是否同意协议
  isAgree: false,
  //验证码是否正确
  codeIsTrue: false,
  //密码是否相同
  isEqual: false,
  phoneNum: "",
  userCode: "",
  serverCdoe: "",
  password: "",
});

//获取验证码
const getUserCode = async () => {
  if (!data.phoneNum) {
    return;
  }
  try {
    const result = await getCode(data.phoneNum);
    data.serverCdoe = result.data;
  } catch (err) {
    console.log(err);
  }
};

//输入验证码
const inputCode = () => {
  data.userCode === data.serverCdoe
    ? (data.codeIsTrue = true)
    : (data.codeIsTrue = false);
};

//再次验证密码
const againPassword = (event: Event) => {
  const target = event.target as HTMLInputElement;
  data.password === target.value
    ? (data.isEqual = true)
    : (data.isEqual = false);
};

//注册
const goRegister = async () => {
  try {
    let result: any = await register({
      phone: data.phoneNum,
      password: data.password,
      code: data.userCode,
    });
    if (result.code === 200) {
      alert("恭喜注册成功");
    } else {
      alert("注册失败");
    }
  } catch (error) {
    console.log(error);
  }
};
</script>

<style lang="less" scoped>
.register-container {
  .register {
    width: 1200px;
    height: 445px;
    border: 1px solid rgb(223, 223, 223);
    margin: 0 auto;

    h3 {
      background: #ececec;
      margin: 0;
      padding: 6px 15px;
      color: #333;
      border-bottom: 1px solid #dfdfdf;
      font-size: 20.04px;
      line-height: 30.06px;

      span {
        font-size: 14px;
        float: right;

        a {
          color: #e1251b;
        }
      }
    }

    div:nth-of-type(1) {
      margin-top: 40px;
    }

    .content {
      padding-left: 390px;
      margin-bottom: 18px;
      position: relative;

      label {
        font-size: 14px;
        width: 96px;
        text-align: right;
        display: inline-block;
      }

      input {
        width: 270px;
        height: 38px;
        padding-left: 8px;
        box-sizing: border-box;
        margin-left: 5px;
        outline: none;
        border: 1px solid #999;
      }

      img {
        vertical-align: sub;
      }

      .error-msg {
        position: absolute;
        top: 100%;
        left: 495px;
        color: red;
      }
    }

    .controls {
      text-align: center;
      position: relative;

      input {
        vertical-align: middle;
      }

      .error-msg {
        position: absolute;
        top: 100%;
        left: 495px;
        color: red;
      }
    }

    .btn {
      text-align: center;
      line-height: 36px;
      margin: 17px 0 0 55px;

      button {
        outline: none;
        width: 270px;
        height: 36px;
        background: #e1251b;
        color: #fff !important;
        display: inline-block;
        font-size: 16px;
      }
    }
  }

  .copyright {
    width: 1200px;
    margin: 0 auto;
    text-align: center;
    line-height: 24px;

    ul {
      li {
        display: inline-block;
        border-right: 1px solid #e4e4e4;
        padding: 0 20px;
        margin: 15px 0;
      }
    }
  }
}
</style>
